<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>BFC</title>
    <style>
        .item {
            margin: 200px;
            width: 200px;
            height: 200px;
            border: 2px solid black;
        }

        .box {
            /* 让box变成BFC 解决margin重叠的问题*/
            /* 2. 让box变成BFC 可以解决浮动导致的高度塌陷 变成BFC的元素计算高度会把浮动元素也计算在内 */
            /* overflow: hidden; */
            /* 1. 设置父元素的高度可以解决高度塌陷问题 */
            /* height: 205px; */

        }

        /* 4. 使用父元素的::after伪元素 伪元素是一个行标签 变成块标签 清除浮动 */
        .box::after {
            content: '';
            display: block;
            clear: right;
        }

        .float {
            width: 200px;
            float: right;
            border: 2px solid black;
            height: 200px;
        }

        .aside {
            width: 150px;
            height: 100px;
            float: left;
            background-color: antiquewhite;
        }

        .main {
            height: 200px;
            background-color: yellowgreen;
        }

        .right {
            /* 变成BFC */
            overflow: hidden;
        }

        .text {
            /* 3.在此处清除浮动 both 清除left和right left right */
            /* clear: right; */
        }
    </style>
</head>

<body>
    <!-- margin 重叠 在同一个BFC  -->
    <!-- <div class="item">123</div>

    <div class="box">
        <div class="item">123</div>
    </div> -->

    <div class="box">
        <div class="float">123</div>
        <div class="float">123</div>
    </div>

    <div class="text">hello world</div>
    <!-- <div class="aside">侧边栏</div>
    <div class="right">
        <div class="main">主页面</div>
    </div> -->
</body>

</html>